#!/usr/bin/bash

# Copyright (c) 2023. Huawei Technologies Co.,Ltd.ALL rights reserved.
# This program is licensed under Mulan PSL v2.
# You can use it according to the terms and conditions of the Mulan PSL v2.
#          http://license.coscl.org.cn/MulanPSL2
# THIS PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
# EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
# MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
# See the Mulan PSL v2 for more details.

# #############################################
# @Author    :   huangdaohong
# @Contact   :   3170809690@qq.com
# @Date      :   2023/3/1
# @License   :   Mulan PSL v2
# @Desc      :   Test bextract
# #############################################

source "${OET_PATH}/libs/locallibs/common_lib.sh"

function pre_test() {
    LOG_INFO "Start to prepare the test environment."
    OLD_LANG=$LANG
    export LANG=en_US.UTF-8
    if yum list | grep -q "mysql5-server"; then
        DNF_INSTALL "bacula-client mysql5-server bacula-common tar"
    else
        DNF_INSTALL "bacula-client mysql-server bacula-common tar"
    fi
    tar -zxvf common/test.tar.gz
    systemctl restart mysqld
    /usr/libexec/bacula/create_mysql_database
    /usr/libexec/bacula/make_mysql_tables
    alternatives --set libbaccats.so /usr/lib64/libbaccats-mysql.so
    sed -i 's\dbuser = "bacula"\dbuser = "root"\g' /etc/bacula/bacula-dir.conf
    systemctl start bacula-dir.service bacula-sd.service
    expect <<EOF
    exp_internal 1
    set timeout -1
    spawn bconsole
    expect "Enter a period to cancel a command." {send "mount\n"}
    expect "Select Storage resource" {send "2\n"}
    expect "Enter autochanger drive" {send "0\n"}
    expect "Enter autochanger slot"  {send "\n"}
    expect "always mounted"  {send "create\n"}
    expect "Select Pool resource" {send "1\n"}
    expect "created" {send "create\n"}
    expect "Select Pool resource" {send "2\n"}
    expect "created" {send "q\n"}
EOF
    expect <<EOF
    exp_internal 1
    set timeout -1
    spawn bconsole
    expect "Enter a period to cancel a command." {send "label\n"}
    expect "Select Storage resource" {send "2\n"}
    expect "Enter autochanger drive" {send "0\n"}
    expect "Enter new Volume name"  {send "testex\n"}
    expect "Enter slot"  {send "0\n"}
    expect "Select the Pool"  {send "1\n"}
    expect "always mounted"  {send "q\n"}
EOF
    LOG_INFO "End to prepare the test environment."
}

function run_test() {
    LOG_INFO "Start to run test."
    bextract -? 2>&1 | grep 'Usage: bextract'
    CHECK_RESULT $? 0 0 "test bextract -? failed"
    bextract -c /etc/bacula/bacula-sd.conf -V testex FileChgr2-Dev1 /tmp | grep 'Ready to read from volume "testex" on File device "FileChgr2-Dev1"'
    CHECK_RESULT $? 0 0 "test bextract -c failed"
    bextract -b ./config/5.conf -V testex FileChgr2-Dev1 /tmp | grep 'Ready to read from volume "testex" on File device "FileChgr2-Dev1"'
    CHECK_RESULT $? 0 0 "test bextract -b failed"
    bextract -v -V testex FileChgr2-Dev1 /tmp | grep 'Ready to read from volume "testex" on File device "FileChgr2-Dev1"'
    CHECK_RESULT $? 0 0 "test bextract -v failed"
    bextract -V testex -d 21 FileChgr2-Dev1 /tmp | grep 'address_conf.c:2[0-9][0-9]-0 Initaddr'
    CHECK_RESULT $? 0 0 "test bextract -d failed"
    bextract -V testex -dt -d 21 FileChgr2-Dev1 /tmp | grep '.*-.*-.* .*:.*:.* bextract: '
    CHECK_RESULT $? 0 0 "test bextract -dt failed"
    bextract -V testex -T FileChgr2-Dev1 /tmp | grep 'Ready to read from volume "testex" on File device "FileChgr2-Dev1"'
    CHECK_RESULT $? 0 0 "test bextract -T failed"
    bextract -V testex -e ./config/e.conf FileChgr2-Dev1 /tmp | grep 'Ready to read from volume "testex" on File device "FileChgr2-Dev1"'
    CHECK_RESULT $? 0 0 "test bextract -e failed"
    LOG_INFO "End to run test."
}

function post_test() {
    LOG_INFO "Start to restore the test environment."
    export LANG=$OLD_LANG
    systemctl stop bacula-dir.service bacula-sd.service
    sed -i 's\dbuser = "root"\dbuser = "bacula"\g' /etc/bacula/bacula-dir.conf
    alternatives --set libbaccats.so /usr/lib64/libbaccats-postgresql.so
    /usr/libexec/bacula/drop_mysql_tables
    /usr/libexec/bacula/drop_mysql_database
    systemctl stop mysqld
    rm -rf config/ /var/lib/mysql/* /tmp/test* /var/spool/bacula/*
    DNF_REMOVE "$@"
    LOG_INFO "End to restore the test environment."
}

main "$@"
